// -*- mode: C++; c-file-style: "cc-mode" -*-
//
// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2008 by Wilson Snyder.
// SPDX-License-Identifier: CC0-1.0

#include <memory>
#include <verilated.h>
#include <verilated_fst_c.h>

#include VM_PREFIX_INCLUDE

unsigned long long main_time = 0;
double sc_time_stamp() { return (double)main_time; }

const char *trace_name() {
  static char name[1000];
  VL_SNPRINTF(name, 1000, VL_STRINGIFY(TEST_OBJ_DIR) "/simpart_%04d.fst",
              (int)main_time);
  return name;
}

int main(int argc, char **argv, char **env) {
  std::unique_ptr<VM_PREFIX> top{new VM_PREFIX("top")};

  Verilated::debug(0);
  Verilated::traceEverOn(true);

  std::unique_ptr<VerilatedFstC> tfp{new VerilatedFstC};
  top->trace(tfp.get(), 99);

  tfp->open(trace_name());

  top->clk = 0;

  while (main_time < 190) { // Creates 2 files
    top->clk = !top->clk;
    top->eval();

    if ((main_time % 100) == 0) {
      tfp->close();
      tfp->open(trace_name());
    }
    tfp->dump((unsigned int)(main_time));
    ++main_time;
  }
  tfp->close();
  top->final();
  tfp.reset();
  top.reset();
  printf("*-* All Finished *-*\n");
  return 0;
}
